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© METHOD OF AND APPARATUS FOR GENERATING AN IMAGE. 



© The method of generating an image of objects in 
a three dimensional space for display on a two 
dimensional pixel array averages N renditions of the 
image, with each rendition having a sub-pixel offset 
from the previous rendition, to produce an anti-alias 
filtering effect. The N sub-pixel offsets are arranged 
to produce a basic array which ensures N times 



oversampling of a selected class or classes of image 
feature. For example, to give good antialias filtering 
of edges closely aligned with the x-y axes of the 
pixel array, the offsets are chosen to ensure bisec- 
tion of the pixel area (A) at N points in each of x and 
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The invention relates to a method of generat- 
ing, from primitive data comprising geometric and 
surface descriptions of a plurality of image primi- 
tives, an image of objects in a three dimensional 
space in a regular, two-dimensional pixel array 
having two principal axes, the method comprising: 

- using the primitive data to render a plurality 
(N) of point-sampled intermediate pixel arrays 
-while imposing for each rendition a different 
offset between the primitives and the sample 
points so as to define a basic array of N 
sample points distributed substantially over 
the area of each pixel; and 

- combining the N intermediate pixel arrays to 
generate a filtered pixel array constituting the 
desired image. 

The invention further relates to an apparatus for 
generating an image of objects in a three dimen- 
sional space in a regular, two-dimensional pixel 
array, the apparatus comprising: 

- means for manipulating primitive data com- 
prising geometric and surface descriptions of 
a plurality of image primitives; 

- rendering means for using the primitive data 
to render a plurality (N) of point-sampled 
pixel arrays while imposing for each rendition 
a different offset between the primitives and 
the sample points; and 

- means for combining the N intermediate pixel 
arrays to generate a filtered pixel array con- 
stituting the desired image. 

A method and apparatus of the type set forth in 
the opening two paragraphs are known from "Fast 
Spheres, shadows, textures, transparencies and im- 
age enhancements in pixel-planes" by Henry 
Fuchs et al in Computer Graphics, Vol. 19, No. 3 
(SIGGRAPR '85) at pages 111 to 120, in particular 
at pages 119 to 120 under "successive refine- 
ment". According to Fuchs et al, "Each pixel (x,y) 
is subdivided into a grid of subpixels so that each 
subpixel has an address of the form (x + xoffset, 
y + yoffset). We generate the image several times 
(16, perhaps), each time offsetting the image slight- 
ly by some (xoffset, yoffset) in such a way that the 
sample points within a pixel's area form a reason- 
able distribution. (The shift is easily achieved by 
adding A.xoffset + B.yoffset to the C coefficient of 
each broadcast triple.) Two sets of color buffers are 
maintained, one to store the color generated by the 
latest image generation offset and the other to 
store a running average as we move around the 
subpixel grid." 

The primary aim of the filtering applied by this 
method is to reduce aliasing artefacts caused by 
the sampling process. One obtrusive artefact of 
aliasing is the "staircase" structure imposed on a 
primitive edge which slopes relative to the pixel 
array axes. This effect can become particularly 
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obtrusive for certain classes of image feature, for 
example primitive edges which are nearly aligned 
with an axis of the pixel array. Unfortunately, using 
a basic array in the form of a simple grid, having 

5 principal axes aligned with those of the pixel array, 
leads to a substantial wastage of the filtering poten- 
tial of N-fold oversampling in the particular case 
outlined where aliasing is most obtrusive. 

This has been recognised in United Kingdom 

w patent application GB-2177577-A, which proposes 
instead to calculate a random or pseudo-random 
distribution of sample points (so-called stochastic 
sampling). This randomisation has the effect of 
replacing aliasing artefacts with noise, on the basis 

75 that random noise is in general more acceptable to 
the human viewer than the regular jagged effects of 
aliasing. However, the generation of the random 
sample distributions in GB-2177577-A is compli- 
cated by measures taken to avoid bunching and 

20 other effects, and optimum antialiasing demands 
that a new random sample pattern is generated for 
each pixel. While it is mentioned in GB-2177577-A 
that, for simplicity, a single randomly generated 
pattern can be used at every pixel location, there is 

25 no guarantee that the filtering of the most obtrusive 
aliasing artifacts will be better than that afforded by 
a regular grid of points. Indeed, with a fixed pat- 
tern, aliasing might be made even worse by the 
stochastic technique. 

30 It is an object of the invention to improve the 

known method of antialias filtering while avoiding 
the drawbacks of stochastic sampling. 

The invention provides a method as set forth in 
the opening paragraph, characterized in that the N 

35 offsets are determined by: 

- selecting one or more classes of image fea- 
ture for filtering; and 

- determining the N offsets of the basic array 
so as to ensure substantially N times over- 

40 sampling of the selected class(es) of image 

feature. 

By this method, the invention allows antialias 
filtering to be implemented at high speed and low 
cost while ensuring that the N sampling points are 

45 fully exploited in the elimination of the most obtru- 
sive aliasing artefacts. 

For example, the selected class of image fea- 
tures may comprise edges which are nearly 
aligned with one or the other axis of the pixel array, 

so the N offsets being chosen so that the pixel area is 
divided at substantially N places in the direction of 
one or both of the principal axes. 

The basic array of N sample points may for 
example be a regular two-dimensional array whose 

55 principal axes are not aligned with the principal 
axes of the pixel array. Such an array improves the 
antialiasing of edges nearly aligned with the pixel 
array axes. Although aliasing for edges nearly 
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aligned with the sub-pixel array axes or other axes 
may increase as a result, aliasing of such edges 
not aligned with axes of the main pixel array is 
inherently less obtrusive, so that an overall benefit 
is obtained. Alternatively, the sub-pixel array of 
sample points may constitute a non-regular two- 
dimensional array. 

The offsets may be chosen so that the sub- 
pixel array of sample points has a bias toward the 
periphery of the pixel area. A wide spread of sam- 
ple points is desirable for edge antialiasing, while a 
low-density central region in the sub-pixel array 
only in itself increases vertex aliasing, which is 
inherently less obtrusive, so that overall benefit 
may be obtained. 

The invention further provides a method as set 
forth in the opening paragraph, characterized in 
that different types of surface information are com- 
bined in the filtered image by using each type of 
surface information for a different subset of the 
renditions. The different types of surface informa- 
tion may for example relate to different primitives, 
to achieve translucency effects, or they may be 
from different texture maps, to provide texture 
blending. 

In such an embodiment, each subset of the 
renditions may be chosen with regard to its own 
filtering characteristic, in the same manner as the 
whole basic array of N points. 

To avoid excessive switching between the dif- 
ferent surface information sources, the renditions 
may be ordered so as to group together the mem- 
bers of each said subset. Alternatively, the rendi- 
tions may be ordered so as to disperse and inter- 
leave the members of the subsets. The latter alter- 
native may be preferable for example when effec- 
ting successive refinements of an image on screen. 

The invention further provides a method as set 
forth in the opening paragraph, characterized in 
that the primitive data are up-dated between rendi- 
tions so that the filtered image incorporates motion 
blurring. Primitives which are moving quickly will 
thus appear appropriately "smeared out" over a 
number of pixels, while stationary primitives can 
benefit from antialiasing provided by the multiple 
renditions. For this purpose, the sub-pixel array 
may be defined to optimise the desired filtering as 
described above. The renditions may also be or- 
dered so that successive sample points are spread 
widely over the pixel area. 

The invention further provides a method as set 
forth in the opening paragraph wherein the image 
is part of a motion picture sequence generated in 
real time, wherein the value of N is chosen adap- 
tively in response to changes in the time required 
for each rendition, so as to maximise the value of 
N while maintaining a predetermined minimum im- 
age rate. This method allows a system having finite 
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rendering performance to maintain an optimum im- 
age quality adapted to scenes of varying complex- 
ity. An adaptive choice of N can be used to simitar 
effect in any multiple rendering system, having 

5 regular or stochastic sample patterns. 

The scene complexity may be determined for 
example by actual measurment of the time taken 
by the system to render the first intermediate pixel 
array, by an estimation based on knowledge of the 

10 primitive data, or by a combination of both. The 

basic array, or even the value of N, may also be * 
varied from pixel to pixel or line to line, to take 
account of different image features present at dif- 
ferent parts of the image. 

75 The invention further provides an apparatus as 

set forth in the second opening paragraph, char- 
acterized in that the N offsets are predetermined in 
accordance with the invention as set forth above. 
Embodiments of the invention will now be de- 

20 scribed, by way of example, with reference to the 
accompanying drawings, in which: 

Figure 1 shows an image synthesis apparatus 
suitable for putting the invention into effect; 
Figure 2 illustrates the principle of antialias filter- 

25 ing by multiple rendition; and 

Figures 3 to 7 show various sample point arrays 
embodying various aspects of the invention. 
Figure 1 shows schematically an apparatus for 
the display of images representing 3-D objects. A 

30 database module OBJ stores and . manages a 
database forming a model of a 3-D environment, 
the "object space", containing various 3-D objects, 
each modelled as a group of object primitives. 
Each primitive may for example be a polygonal 

35 surface or a curved patch, which in turn is defined 
by a geometric description (for example vertex 
coordinates) and a surface description (colour, tex- 
ture, transparency, surface normal, etc.). Geometric 
and surface descriptions of light sources may also 

40 be included. Another module VEW defines a 
"viewing space", for example in terms of the posi- 
tion of a viewpoint, the direction of view and the 
field of view. 

User input means INP, such as a tracker ball, 

45 mouse and/or keyboard are connected to a 
human/computer interface module HCI which al- 
lows a user to manipulate or modify objects within 
the object space or manipulate the viewpoint, di- 
rection of view and other attributes of the viewing 

50 space. 

A geometry module GEOM performs geometric 
transformations to translate the various object 
space geometric descriptions of primitives, defined 
in the database module OBJ, to equivalent descrip- 
55 tions in the viewing space. These transformations 
will generally include translation, rotation and per- 
spective, as is well-known in the art. The surface 
descriptions of the primitives are also modified in 

3 
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accordance with lighting conditions in viewing 
space. In the normal case where the image is only 
two-dimensional, coordinates in the viewing space 
in two dimensions (typically called x and y) will 
correspond linearly to screen coordinates, while a 
third coordinate (z) corresponds to the "depth" of 
an object "into" the screen. 

The geometry module GEOM passes the view- 
ing space primitive descriptors to a rendering mod- 
ule DRW which converts the viewing space primi- 
tive descriptions into a form suitable for display, 
typically by scan conversion into a 2-D array of 
pixel values in an image buffer memory IMINT. The 
rendering module DRW may perform calculations 
for hidden-surface removal (using the z coordi- 
nates) and shading. Suitable means for performing 
such tasks are well-known in the art. 

In accordance with the multiple-rendition tech- 
nique described by Fuchs et al in the reference 
cited above, the pixel array Tn the buffer IMINT is 
an intermediate, point sampled image. For each 
image appearing on the display device DIS, a set 
of N intermediate images are so rendered, and a 
module OFFS supplies for each of the N ren- 
derings a different predetermined offset, so that the 
sample point for each pixel moves between ren- 
derings. An image accumulator buffer IMACC adds 
together the intermediate images as they are gen- 
erated so that after N renderings the buffer IMACC 
contains an image which has been oversampled 
and filtered in accordance with the sample point 
distribution and any weightings that may be at- 
tached to each sample point. 

If successive refinements of the image are to 
be displayed as soon as they are available, as 
described by Fuchs et al (for example if the buffer 
IMACC is not double-buffered), then the values 
maintained in the buffer IMACC should be nor- 
malised so as to form a true running average after 
each rendition. Otherwise, the intermediate pixel 
values can simply be added together and divided 
by N after all renditions to obtain the final average. 
Division by N can be greatly simplified if N is 
limited to powers of two (2,4,8,16 etc). 

In practice, the offsets may be used to move 
the primitives relative to a stationary sample point 
array. For clarity, however, Figure 2 illustrates the 
reverse situation where a primitive P, having an 
edge E and a vertex V, remains stationary over a 
square array of pixel areas A,B etc., while N = 16 
different sub-pixel offsets effect point sampling at 
the points marked with dots within each of the two 
representative pixel areas A and B. 

The sample point arrays shown for pixels A 
and B are identical and are repeated (not illus- 
trated) in every pixel area of the pixel array, in 
accordance with a basic sub-pixel array defined by 
the set of N = 16 offsets. It can be seen that in the 
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sub-pixel array in Figure 2 the sample points are 
placed at the centres of a square grid of 16 sub- 
pixels. 

If we assume, for simplicity, that the shaded 
5 primitive P has a colour value of 1 and the back- 
ground has a value of 0, it can be seen from Figure 
2 that the final average value for pixel A will be 
7/16 or 8/16, and that for pixel B will be 5/16 or 
6/16. These fractions represent the fraction of the 
w pixel area covered by the primitive, quantized in 
16ths of a pixel, so that the image in the accumula- 
tor buffer IMACC is at least approximately antialias 
filtered. 

Aliasing is a problem which is more apparent 
75 on some features of an image than others. In 
particular, an edge such as the edge E which 
slopes very slightly with respect to the principal 
axes x and y of the pixel array tends to generate 
very visible "staircase" effects. This is particularly 
20 disturbing in motion picture image sequences, 
when the steps of the staircase appear to run at 
high speed along the edge E as it moves for 
example to positions E' and E" in successive im- 
ages. 

25 Figure 2 shows how the regular grid pattern 

uses the potential 16 quantisation levels inefficient- 
ly, particularly in the case described when aliasing 
is generally most obtrusive. As the primitive edge 
E moves to position E\ the filtered colour value 

30 remains constant at 8/16. Then, in the short space 
between E f and E", the value jumps four levels to 
12/16. In effect, as the relevant edge approaches 
horizontal (or vertical), the N ( = 16) quantisation 
levels potentially available are effectively reduced 

35 to only VN ( = 4) levels, so that twelve of the 
sixteen renditions are effectively made redundant 
in the situation where good filtering is most need- 
ed. The effort of 16 times oversampling has been 
expended to yield the benefit of only 4 times 

40 oversampling. 

Figures 3 to 7 show a series of novel sampling 
arrays, with N = 4, 8 or 16 sample points, as in- 
dicated. Solid dots represent the basic array of 
sample points for pixel area A, while open circles 

45 represent sample points of neighbouring pixel 
areas. The novel arrays are arranged so that the 
edge E of a primitive which is nearly aligned with 
the x or y axis crosses the sample points one at a 
time as it moves in the y or x direction respec- 

50 tively, rather than in groups as with the array of 
Figure 2. 

In particular, the arrays of Figures 3, 4, 5 and 7 
are such that the pixel area A is divided at exactly 
N different places in both x and y directions. The 8 
55 points of intersection are marked by arrows along 
the edges of the pixel area A in Figure 4. This 
property can be compared with the array of Figure 
2 in which only VN points of intersection are af- 

4 
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forded by N sample points. 

The advantage of providing N intersection 
points is that all N quantisation levels are used to 
antialias an edge which is near-horizontal, or near- 
vertical. The sub-pixel array of 16 sample points 
shown in Figure 5 is a regular array, with axes £ 
and rj inclined relative to x and y. This has the 
consequence that only 4 effective quantisation lev- 
els are obtained in the pixel in the special case 
where an edge is parallel to one of the array axes £ 
or ij. This may not be a significant problem, since 
edge aliasing is inherently less obtrusive for slop- 
ing edges which slope markedly with respect to the 
principal axes of the pixel array. It may be noted in 
this respect that the sample point array of Figure 5 
is not coherent across the pixel boundaries. 

It is desirable that the sample points should be 
distributed widely and evenly across the pixel 
areas. With this in mind, the basic array in Figure 3 
may appear to give an undesirable diagonal bunch- 
ing of sample points, top-left to bottom-right. It will 
be seen however, that a better spread of sample 
points is in fact provided with the N = 4 sample 
points per pixel when one takes into account the 
interleaved contributions from pixels in alternate 
diagonal rows. 

Figure 6 shows an alternative basic array 
where N = 16. This basic array is non-regular, 
thereby avoiding the special case problem men- 
tioned above. Also, the array of Figure 6 has a 
distribution of sample points which is biased to the 
periphery of the area A, even at the expense of a 
slightly under-sampled region in the centre of the 
area A. Regions where there is a low sampling 
density result in poorer antialiasing at primitive 
vertices, but a good compromise can be reached 
here, particularly since in a typical image pixels at 
vertices of primitives are generally much fewer 
than pixels along edges of primitives. It may be 
noted that two pairs of sample points coincide in 
each of x and y, so that there are only fourteen 
points of intersection in x and y instead of N(= 16). 
This can still be regarded as providing substantially 
N points of intersection, when compared with the 
VN( = 4) points of bisection provided by the array 
in Figure 2. 

Figure 7 shows an array with N=8 which at- 
tains a wide spread of points over the pixel area A, 
while providing denser coverage of the central re- 
gion of the pixel area A, when compared with that 
of Figure 4. The criterion that N=8 intersection 
points should be provided in both x and y is still 
fully met. 

Further variations on these patterns are possi- 
ble. For example in some embodiments, for exam- 
ple where successive refinements are displayed, it 
might be advantageous to have a series of basic 
arrays with N = 4, 8, 16 etc. so that each array is a 
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superset of the previous array. Also different, 
weighting coefficients could be attached to the 
points to achieve more general filtering actions. 
Another variation may be termed adaptive mul- 

s tiple rendition, and may be useful where the ap- 
paratus of Figure 1 is generating in real-time mo- 
tion picture sequences where images are of widely 
varying complexity, for example in flight simulation 
applications. For this purpose, the module OFFS in 

w Figure 1 receives a complexity signal COMP for 
each image and modifies the number N of rendi- * 
tions so as to maintain the best image filtering (for 
example for antialiasing) which is consistent with a 
desired image update rate. The complexity signal 

75 COMP should represent the amount of time taken 
for the rendering module DRW to make each rendi- 
tion. The signal COMP may for example be ob- 
tained by direct feedback from the module DRW of 
the time taken for the first rendition. That is, if less 

20 than 50% of the time available is used for the first 
rendition, then another rendition can be made. This 
can further be generalised to determine the num- 
ber of renditions which can be made given the total 
time available and the time taken per rendition, that 

25 is the number of renditions available is equal to the 
total time available divided by the time per rendi- 
tion. Alternatively, it may be supplied by the geom- 
etry module GEOM, if that module contains means 
for estimating rendering time, for example by total- 

30 ling the screen areas of all primitives in the image 
or a prediction of image complexity could be made 
based on time taken to render the previous image 
in the motion picture sequence, possibly sup- 
plemented with a complexity-change signal from 

35 the geometry module GEOM. 

Various special effects are attainable by divid- 
ing the N offsets defining the basic array of sample 
points into two or more subsets. For this purpose, 
subsets of points can be chosen so that each sub- 

40 array meets to some extent the criteria for good 
filtering as set forth above in relation to the whole 
array. Two such subsets are distinguished in Fig- 
ure 6 by means of crosses superimposed on a first 
subset of eight of the sixteen sample points in the 

45 basic array. 

One effect that can be achieved by use of 
subsets is tonal mixing. For example, by rendering 
the first subset of sample points in accordance with 
the tonal description of a foreground primitive, and 

50 the second subset in accordance with that of a 
background primitive, translucency of the fore- 
ground primitive is simulated, while antialias filter- 
ing is still effected at the edges of the foreground 
primitive with a resolution of N/2 = 8 quantisation 

55 levels. 

Another application of tonal mixing by multiple 
rendition is the mixing of textures from two different 
texture maps. For example a fine, repetitive texture 

5 
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in luminance could be blended with a broader 
colour texture by rendering the first subset using 
one texture map and the second subset using 
another. In this context, "texture mapping" is to be 
taken as including a whole family of applications of 5 
mapping, a number of which are described for 
example by Paul S. Heckbert in his paper "A 
Survey of Texture Mapping", in IEEE Computer 
Graphics and Applications, November 1986 at 
pages 56 to 67. ro 

For the purpose of such techniques, the sam- 
ple points in Figure 6 have been ordered in accor- 
dance with the numbers 1 to 16 marked in the 
Figure. The ordering groups together the first sub- 
set as numbers 1 to 8 and the second subset as 15 
numbers 9 to 16. When the module OFFS supplies 
the offsets in the corresponding order, the render- 
ing module DRW need switch only once between 
the two sources of the two tonal descriptions which 
are being combined, which may save time in some 20 
embodiments. 

Ordering the renditions as shown also has ad- 
vantages when successive refinement is being im- 
plemented on-screen using the whole array without 
blending, since the order illustrated is such that a 25 
wide and even spread of sample points is obtained 
after only a few renditions, so that each succes- 
sively refined image will be optimally filtered. When 
subsets of the renditions are used for tonal mixing 
in a successive refinement embodiment, it may be 30 
advantageous for the rendition sequence to be 
such that the members of the subsets are dis- 
persed and interleaved in the sequence, thereby 
avoiding dramatic changes in the image's appear- 
ance as the successive renditions are added into 35 
the running average in the accumulator buffer IM- 
ACC. 

Another effect that can be obtained by multiple 
rendition is that of motion blur. By updating the 
object and view databases (modules OBJ and 40 
VEW) between renditions, to simulate motion of the 
object and the viewer in a period which is 1/N 
times an image period, the different samples are 
effectively spread in time as well as space, and 
fast moving objects will appear smeared out over 45 
an area of the image which corresponds to the 
distance moved by the primitive during the said 
image period. For this effect, correct ordering of 
the renditions is also important, again so as to 
achieve a wide and even spread of sample points so 
as the array builds up. There is a trade-off so that 
filtering quality is lost for fast moving primitives, 
while full filtering is maintained for slow or station- 
ary primitives. Those skilled in the art will recog- 
nize that this trade-off is entirely appropriate in a 55 
motion picture sequence, since the human eye is 
not sensitive to detail on fast-moving objects. 

It may be noted that a co-pending United King- 
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dom Patent application No. 9014555.8 (PHB33648) 
of the same applicants, having the same priority 
date as the present application, describes a 
multiple-rendition method implemented on a row- 
by-row (scanline) basis, so that the intermediate 
image buffer IMINT need only store data for a 
single row of pixels at a time. The contents of that 
other application are hereby incorporated herein by 
reference. 

From reading the present disclosure, further or 
alternative variations and combinations will be ap- 
parent to persons skilled in the art. Such variations 
may involve other features which are already 
known in the design, manufacture and use of im- 
age generating methods and apparatuses and com- 
ponent parts thereof and which may be used in- 
stead of or in addition to features already de- 
scribed herein. Although claims have been formu- 
lated in this application to particular combinations 
of features, it should be understood that the scope 
of the disclosure of the present application also 
includes any novel feature or any novel combina- 
tion of features disclosed herein either explicitly or 
implicitly or any generalisation thereof, whether or 
not it relates to the same invention as presently 
claimed in any claim and whether or not it miti- 
gates any or all of the same technical problems as 
does the present invention. The applicants hereby 
give notice that new claims may be formulated to 
such features and/or combinations of such features 
during the prosecution of the present application or 
of any further application derived therefrom. 

Claims 

1. A method of generating, from primitive data 
comprising geometric and surface descriptions 
of a plurality of image primitives, an image of 
objects in a three dimensional space in a regu- 
lar, two-dimensional pixel array having two 
principal axes, the method comprising: 

- using the primitive data to render a plu- 
rality (N) of point-sampled intermediate 
pixel arrays while imposing for each ren- 
dition a different offset between the 
primitivesand the sample points so as to 
define a basic array of N sample points 
distributed substantially over the area of 
each pixel; and 

- combining the N intermediate pixel ar- 
rays to generate a filtered pixel array 
constituting the desired image; character- 
ized in that the N offsets are determined 
by: 

- selecting one or more classes of image 
feature for filtering; and 

- determining the N offsets of the basic 
array so as to ensure substantially N 
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times oversampling of the selected class- 
es) of image feature. 

2. A method as claimed in Claim 1, wherein the 
selected class of image features comprises 5 
edges which are nearly aligned with one or the 
other principal axis of the pixel array, the N 
offsets being chosen so that the pixel area is 
divided at substantially N places in the direc- 
tion of one or both of the principal axes. 10 

3. A method as claimed in Claim 1 or 2, wherein 
the basic array of N sample points is a regular 
two-dimensioned array whose principal ones 

are not aligned with the principal axes of the 15 
pixel array. 

4. A method as claimed in Claim 1, 2 or 3, 
wherein the offsets are chosen so that the sub- 
pixel array of sample points has a bias toward 20 
the periphery of the pixel area. 

5. A method as claimed in any of Claims 1 to 4, 
in which different types of surface information 

are combined in the filtered image by using 25 
each type of surface information for a different 
subset of the renditions. 

6. A method as claimed in Claim 5, wherein dif- 
ferent subsets of the renditions are performed 30 
using surface information relating to different 
primitives. 

7. A method as claimed in Claim 5, wherein dif- 
ferent subsets of the renditions are performed 35 
using surface information from different texture 
maps. 

8. A method as claimed in Claim 5, 6 or 7, 
wherein the renditions are ordered so as to 40 
group together the members of each of the 

said subsets. 

9. A method as claimed in Claim 5, 6 or 7, 
wherein the renditions are ordered so as to 45 
disperse and interleave the members of the 

said subsets. 

10. A method as claimed in any preceding claim, 

in which the image is part of a motion picture 50 
sequence generated in real time, the value of 
N being chosen adaptively in response to 
changes in the time required for each rendition 
so as to maximise N while maintaining a pre- 
determined minimum image rate. 55 
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